package com.breeze.blockchain.auth.anno.admin;

import cn.dev33.satoken.annotation.SaCheckRole;
import cn.dev33.satoken.annotation.SaMode;
import com.breeze.blockchain.auth.util.AdminUserUtil;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
import org.springframework.core.annotation.AliasFor;

/**
 * 角色认证校验：必须具有指定角色标识才能进入该方法。
 *
 * <p>可标注在方法、类上（效果等同于标注在此类的所有方法上）
 *
 * @author click33
 * @since 1.10.0
 */
@SaCheckRole(type = AdminUserUtil.TYPE)
@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.METHOD, ElementType.TYPE})
public @interface AdminCheckRole {

  /**
   * 需要校验的角色标识 [ 数组 ]
   *
   * @return /
   */
  @AliasFor(annotation = SaCheckRole.class)
  String[] value() default {};

  /**
   * 验证模式：AND | OR，默认AND
   *
   * @return /
   */
  @AliasFor(annotation = SaCheckRole.class)
  SaMode mode() default SaMode.AND;
}
